//给你一个整数 columnNumber ，返回它在 Excel 表中相对应的列名称。 
//
// 例如： 
//
// 
//A -> 1
//B -> 2
//C -> 3
//...
//Z -> 26
//AA -> 27
//AB -> 28 
//...
// 
//
// 
//
// 示例 1： 
//
// 
//输入：columnNumber = 1
//输出："A"
// 
//
// 示例 2： 
//
// 
//输入：columnNumber = 28
//输出："AB"
// 
//
// 示例 3： 
//
// 
//输入：columnNumber = 701
//输出："ZY"
// 
//
// 示例 4： 
//
// 
//输入：columnNumber = 2147483647
//输出："FXSHRXW"
// 
//
// 
//
// 提示： 
//
// 
// 1 <= columnNumber <= 2³¹ - 1 
// 
//
// Related Topics 数学 字符串 👍 730 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public String convertToTitle(int columnNumber) {
//        String str= "";
//        while(columnNumber > 0){
//            columnNumber --;
//            int num = columnNumber % 26;
//            char z = (char) ('A' + num);
//            str = z + str;
//            columnNumber /= 26;
//        }
//        return str;
        StringBuilder stringBuilder = new StringBuilder();
        while(columnNumber > 0){
            columnNumber --;//减1，将1-26映射为0-25， 适配ASCII码计算
            char c = (char) (columnNumber%26 + 'A');
            stringBuilder.append(c);
            //处理更高位
            columnNumber /= 26;
        }
        return stringBuilder.reverse().toString();


    }
}
//leetcode submit region end(Prohibit modification and deletion)
